<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <script src="./libs/bootstrap/js/bootstrap.min.js"></script>
    <!-- 引入分页插件twbs-pagination插件的js -->
    <script src="./libs/jquery.twbsPagination.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <!-- 分页插件结构 -->
                <ul class="pagination" id="pagination"></ul>
                <p>没有数据!</p>
            </div>
        </div>
    </div>

    <!-- 准备一个 文章类别 模板 -->
    <script id="category_temp" type="text/html">
        <option value="">所有分类</option>
        {{each data v}}
        <option value="{{v.id}}">{{v.name}}</option>
        {{/each}}
    </script>

    <!-- 准备一个 文章列表 模板 -->
    <script id="articleList_temp" type="text/html">
        {{each data.data v}}
        <tr>
            <td>{{v.title}}</td>
            <td>{{v.author}}</td>
            <td>{{v.category}}</td>
            <td class="text-center">{{v.date}}</td>
            <td class="text-center">{{v.state}}</td>
            <td class="text-center">
                <a href="article_edit.html?id={{v.id}}" class="btn btn-default btn-xs">编辑</a>
                <a href="javascript:void(0);" data-id="{{v.id}}" class="btn btn-danger btn-xs delete">删除</a>
            </td>
        </tr>
        {{/each}}
    </script>

    <!-- 导入http.js文件 -->
    <script src="./libs/http.js"></script>
    <script>
        //入口函数
        $(function () {
            //一:发送ajax请求,获取所有的文章类别,然后通过模板引擎的方式渲染到下拉菜单中. 
            $.ajax({
                type: 'get',
                url: BigNew.category_list,
                success: function (backData) {
                    //console.log(backData);
                    if (backData.code == 200) {
                        //通过模板引擎 渲染到下拉菜单中
                        var resHtml = template('category_temp', backData);
                        $('#selCategory').html(resHtml);
                    }
                }
            });





            //------------------------------------------------------------
            var currentPage = 1; //当前页码

            //封装:发送ajax请求,根据条件获取对应的所有文章数据,封装成一个函数. 
            //myPage就是当前的页码
            //callback就是渲染数据完成后要做的事情. 
            function getData(myPage, callback) {
                $.ajax({
                    type: 'get',
                    url: BigNew.article_query,
                    data: {
                        type: $('#selCategory').val(), //选中的文章类别
                        state: $('#selStatus').val(), //选中的文章状态(草稿/已发布)
                        page: myPage, //页码每次调用的时候不一样,所以不能写死
                        perpage: 3
                    },
                    success: function (backData) {
                        console.log(backData);
                        if (backData.code == 200) {
                            //调用模板引擎核心方法
                            var resHtml = template('articleList_temp', backData);
                            $('tbody').html(resHtml);

                            //额外的事情
                            //判断响应回来有没有数据. 
                            if (backData.data.data.length !=0 && callback != null) {
                                //有数据
                                $('#pagination').show().next('p').hide();
                                //把获取回来的数据在调用callback的时候作为实参传递
                                callback(backData);
                            }
                            //如果你当前页是1,并且发送ajax请求又没有文章数,
                            //那就说明你这个文章分类 中确实没有文章. 
                            else if(backData.data.data.length == 0 && currentPage == 1){
                                //没有数据
                                $('#pagination').hide().next('p').show();
                            }
                            else if(backData.data.totalPage == currentPage-1 && backData.data.data.length == 0) {
                                currentPage -= 1;
                                //重新的绘制分页结构
                                $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, currentPage);
                            }
                        }
                    }
                });
            }

            //二:一进到页面,发送ajax请求,获取默认的文章类别/文章状态 下的所有文章. 
            getData(1, function (backData) {
                //分页插件的方法. 
                $('#pagination').twbsPagination({
                    totalPages: backData.data.totalPage, //总页数
                    visiblePages: 7, //最大的可见页数
                    first: '首页',
                    prev: '上一页',
                    next: '下一页',
                    last: '尾页',
                    //页码点击的回调函数事件
                    onPageClick: function (event, page) {
                        currentPage = page; //给当前页码赋值

                        //console.log(page); //是当前点击的页码数,比如第5页
                        //重新发送ajax请求,把当前点击的这个页码传进去. 
                        getData(page, null); //调用我们自己封装的方法
                    }
                });
            });

            //三:点击筛选按钮,获取符合条件 的文章们,渲染到页面上. 
            $('#btnSearch').on('click', function (e) {
                e.preventDefault(); //阻止默认的提交行为
                //把当前页改成1
                currentPage = 1;
                //发送ajax请求
                getData(1, function (backData) {
                    //点击筛选按钮,由于改变了筛选条件,所以筛选出来的数据总页码会发生改变. 
                    //所以要根据新的总页数, 来重新绘制 分页结构. 
                    $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, 1);
                })
            })


            //四:删除文章
            //给删除按钮设置点击事件(委托注册)
            $('tbody').on('click','.delete',function(){
                if(confirm('你确定要删除吗?')){
                    //通过当前点击的删除按钮(a标签)的这个自定义属性(data-id)来获取当前要删除的文章id
                    var articleId = $(this).attr('data-id');
                    //发送ajax请求完成删除
                    $.ajax({
                        type:'post',
                        url:BigNew.article_delete,
                        data:{
                            id:articleId
                        },
                        success:function(backData){
                            console.log(backData);
                            if(backData.code == 204){
                                //删除成功,要重新加载数据. 
                                //由于删除了数据,那总的页码就有可能减少
                                //那就应该根据新的总页码 重新生成 分页结构
                                getData(currentPage,function(backData){
                                    //重绘分页结构
                                    $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, currentPage);
                                });
                            }
                        }
                    });
                }
            })


            //五:点击 发表文章 按钮
            //左边导航栏,导航到发表文章那里. 
            $('#release_btn').on('click',function(){
                parent.$('ul.level02>li:eq(1)').click();
            });













            //-----------------------------------------------------------------------
            //二:一进到页面,发送ajax请求,获取默认的文章类别/文章状态 下的所有文章. 
            // $.ajax({
            //     type: 'get',
            //     url: BigNew.article_query,
            //     data: {
            //         type: $('#selCategory').val(), //选中的文章类别, 默认是所有分类
            //         state: $('#selStatus').val(), //状态(草稿/已发布), 默认是所有的状态
            //         page: 1,
            //         perpage: 3
            //     },
            //     success: function (backData) {
            //         console.log(backData);
            //         if (backData.code == 200) {
            //             //调用模板引擎核心方法
            //             var resHtml = template('articleList_temp', backData);
            //             $('tbody').html(resHtml);

            //             //分页插件的方法. 
            //             $('#pagination').twbsPagination({
            //                 totalPages: backData.data.totalPage, //总页数
            //                 visiblePages: 7, //最大的可见页数
            //                 first: '首页',
            //                 prev: '上一页',
            //                 next: '下一页',
            //                 last: '尾页',
            //                 //页码点击的回调函数事件
            //                 onPageClick: function (event, page) {
            //                     //console.log(page); //是当前点击的页码数,比如第5页
            //                     //重新发送ajax请求,把当前点击的这个页码传进去. 
            //                     $.ajax({
            //                         type: 'get',
            //                         url: BigNew.article_query,
            //                         data: {
            //                             type: $('#selCategory').val(), //选中的文章类别
            //                             state: $('#selStatus').val(), //选中的文章状态(草稿/已发布)
            //                             page: page, //此时这里是是点击的页码
            //                             perpage: 3
            //                         },
            //                         success: function (backData) {
            //                             if (backData.code == 200) {
            //                                 //调用模板引擎核心方法
            //                                 var resHtml = template('articleList_temp',backData);
            //                                 $('tbody').html(resHtml);
            //                             }
            //                         }
            //                     });
            //                 }
            //             });
            //         }
            //     }
            // });


            // //三:点击筛选按钮,获取符合条件 的文章们,渲染到页面上. 
            // $('#btnSearch').on('click', function (e) {
            //     e.preventDefault(); //阻止默认的提交行为
            //     //发送ajax请求
            //     $.ajax({
            //         type: 'get',
            //         url: BigNew.article_query,
            //         data: {
            //             type: $('#selCategory').val(), //选中的文章类别
            //             state: $('#selStatus').val(), //选中的文章状态(草稿/已发布)
            //             page: 1,
            //             perpage: 3
            //         },
            //         success: function (backData) {
            //             console.log(backData);
            //             if (backData.code == 200) {
            //                 //调用模板引擎核心方法
            //                 var resHtml = template('articleList_temp', backData);
            //                 $('tbody').html(resHtml);

            //                 //点击筛选按钮,由于改变了筛选条件,所以筛选出来的数据总页码会发生改变. 
            //                 //所以要根据新的总页数, 来重新绘制 分页结构. 
            //                 $('#pagination').twbsPagination('changeTotalPages',backData.data.totalPage,1);
            //             }
            //         }
            //     });
            // })
            //-----------------------------------------------------------------------



        });
    </script>
</body>

</html>